xen.git
17 years agotxt: Xen per-domain S3 integrity config
Keir Fraser [Tue, 3 Mar 2009 11:52:44 +0000 (11:52 +0000)]
txt: Xen per-domain S3 integrity config

This patch adds a per-domain flag to specify whether a domain will be
S3 integrity protected when Xen is launched using tboot/TXT.

The tools now support an integer domain configuration parameter called
's3_integrity', which defaults to 1, to enable S3 integrity protection.

The struct arch_domain structure has been extended to have an
's3_integrity' field that represents this setting.

Signed-off-by: Shane Wang <shane.wang@intel.com>
Signed-off-by: Joseph Cihula <joseph.cihula@intel.com>
17 years agohvm: passthrough MSI-X: fix ia64 link and MSI-X clean up
Keir Fraser [Tue, 3 Mar 2009 11:46:52 +0000 (11:46 +0000)]
hvm: passthrough MSI-X: fix ia64 link and MSI-X clean up

This patch fixes the ia64 link error and some clean up of MSI-X code.
- add ia64 dummy function to link
- fix unmatched prototype
- add error check

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years agolibxen: fix a problem preventing use of xen_event_register().
Keir Fraser [Tue, 3 Mar 2009 11:41:15 +0000 (11:41 +0000)]
libxen: fix a problem preventing use of xen_event_register().

The conversion of input parameter xen_string_set to XML format creates
a XML "struct" tag instead of "array". The patch sets the XML tag for
SET now to "array".

Signed-off-by: Lutz Dube <Lutz.Dube@fujitsu-siemens.com>
17 years agoxend: Make /var/lib/xen if not already present.
Keir Fraser [Tue, 3 Mar 2009 11:37:31 +0000 (11:37 +0000)]
xend: Make /var/lib/xen if not already present.
Signed-off-by: Christoph Egger <christoph.egger@amd.com>
17 years agoia64: fix build.
Keir Fraser [Mon, 2 Mar 2009 16:24:50 +0000 (16:24 +0000)]
ia64: fix build.
Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agoWhen a domain crashes, ignore shutdown deferrals.
Keir Fraser [Mon, 2 Mar 2009 14:09:21 +0000 (14:09 +0000)]
When a domain crashes, ignore shutdown deferrals.

Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agox86: Minimize the TSC drift between pCPUs
Keir Fraser [Mon, 2 Mar 2009 13:56:47 +0000 (13:56 +0000)]
x86: Minimize the TSC drift between pCPUs
Signed-off-by: Xiaowei Yang <xiaowei.yang@intel.com>
17 years agovtd: boolean boot parameter to allow inclusive mapping of all memory below 4GB
Keir Fraser [Mon, 2 Mar 2009 11:23:23 +0000 (11:23 +0000)]
vtd: boolean boot parameter to allow inclusive mapping of all memory below 4GB

Signed-off-by: Ross Philipson <ross.philipson@citrix.com>
17 years agox86: Make offlined CPU enter deepest C state
Keir Fraser [Mon, 2 Mar 2009 11:11:19 +0000 (11:11 +0000)]
x86: Make offlined CPU enter deepest C state

Before cpuidle is introduced, offlined CPU only enter C1 (by HLT
instruction). This is not optimal since C2/C3 can bring more power
saving. Since now cpuidle is introduced, it is time for offlined CPU
to enter more deeper C state.

This patch add the logic to make offlined CPU enter deepest C state,
if cpuidle is enabled.

Signed-off-by: Yu Ke <ke.yu@intel.com>
Signed-off-by: Wei Gang <gang.wei@intel.com>
Signed-off-by: Tian Kevin <kevin.tian@intel.com>
17 years agoxmexample: portability fix
Keir Fraser [Mon, 2 Mar 2009 11:04:43 +0000 (11:04 +0000)]
xmexample: portability fix

Signed-off-by: Christoph Egger <Christoph.Egger@amd.com>
17 years agoxen, pci: Fix the definition of PCI_PM_CTRL_NO_SOFT_RESET.
Keir Fraser [Mon, 2 Mar 2009 11:01:06 +0000 (11:01 +0000)]
xen, pci: Fix the definition of PCI_PM_CTRL_NO_SOFT_RESET.

Signed-off-by: Dexuan Cui <dexuan.cui@intel.com>
17 years agominios: general cleanup of mm.c
Keir Fraser [Mon, 2 Mar 2009 10:52:07 +0000 (10:52 +0000)]
minios: general cleanup of mm.c

Major clean up of mm.c. Added comments, fixed coding style, more
sensible variable names, mark some local functions static etc.

Signed-off-by: Rolf Neugebauer <rolf.neugebauer@netronome.com>
Acked-by: Samuel Thibault <samuel.thibault@ens-lyon.org>
17 years agominios: cleanup events.c
Keir Fraser [Mon, 2 Mar 2009 10:51:34 +0000 (10:51 +0000)]
minios: cleanup events.c

Don't throw away hypercall error codes. They might be useful. Also
some minor coding style cleanups.

Signed-off-by: Rolf Neugebauer <rolf.neugebauer@netronome.com>
Acked-by: Samuel Thibault <samuel.thibault@ens-lyon.org>
17 years agominios: add ioremap/iounmap
Keir Fraser [Mon, 2 Mar 2009 10:50:59 +0000 (10:50 +0000)]
minios: add ioremap/iounmap

Add ioremap and iounmap functions to minios. Also move some unmapping
code from and clean up mem_test.

Signed-off-by: Rolf Neugebauer <rolf.neugebauer@netronome.com>
Acked-by: Samuel Thibault <samuel.thibault@ens-lyon.org>
17 years agoxend: Fix removing /vm/UUID/device paths when device cannot be disconnected
Keir Fraser [Mon, 2 Mar 2009 10:34:37 +0000 (10:34 +0000)]
xend: Fix removing /vm/UUID/device paths when device cannot be disconnected

Change deviceDestroy behavior to remove /vm/UUID/device/...
path only when force was used (as it already does so for both frontend
and backend) and do the removing from xen-hotplug-cleanup script when we
are sure the device is really not attached to the guest any more.

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
17 years agox86: Small fix for gpf when writing 1s to MCi_STATUS MSRs.
Keir Fraser [Mon, 2 Mar 2009 10:32:32 +0000 (10:32 +0000)]
x86: Small fix for gpf when writing 1s to MCi_STATUS MSRs.

According to spec, only 0s is allowed to be written. This error is
found when do cpu-offline, cmci happens.
For avoiding missing future cmci after changing cmci owner, we need to
process pending cmci errors to clear MCi_STATUS MSRs.

Signed-off-by: Ke Liping <liping.ke@intel.com>
Signed-off-by: Jiang Yunhong <yunhong.jiang@intel.com>
17 years agoacm: Return a valid buffer
Keir Fraser [Mon, 2 Mar 2009 10:31:16 +0000 (10:31 +0000)]
acm: Return a valid buffer

This patch reverts a previous patch trying to fix a memory, even
though I don't think there was any. Now return a valid buffer. All
functions calling this function do free the buffer.

Signed-off-by: Stefan Berger <stefanb@us.ibm.com>
17 years agohvmloader: Make build fail if packages required to build hvmloader not present
Keir Fraser [Mon, 2 Mar 2009 10:30:15 +0000 (10:30 +0000)]
hvmloader: Make build fail if packages required to build hvmloader not present

Also, corrected the message generated by the makefile which says what
packages are required.

Signed-off-by: Alex Zeffertt <alex.zeffertt@eu.citrix.com>
Acked-by: Ian Jackson <ian.jackson@eu.citrix.com>
17 years agohvm: passthrough MSI-X mask bit acceleration
Keir Fraser [Mon, 2 Mar 2009 10:26:37 +0000 (10:26 +0000)]
hvm: passthrough MSI-X mask bit acceleration

Add a new parameter to DOMCTL_bind_pt_irq to allow Xen to know the
guest physical address of MSI-X table. Also add a new MMIO intercept
handler to intercept that gpa in order to handle MSI-X vector mask
bit operation in the hypervisor. This reduces the load of device model
considerably if the guest does mask and unmask frequently

Signed-off-by: Qing He <qing.he@intel.com>
17 years agoxend: Fix some mistakes in tools/python/xend/util/pci.py
Keir Fraser [Mon, 2 Mar 2009 10:23:50 +0000 (10:23 +0000)]
xend: Fix some mistakes in tools/python/xend/util/pci.py

1) PCI_PM_CTRL_NO_SOFT_RESET: this is bit3 of PMCSR(Power Management
Control/Status). It should be 8. This bit means a device's capability
of not doing an internal reset across D3hot/D0.
If the bit is 1, there shall be no reset across D3hot/D0, so we should
not use it as a method to reset device.
2) When performing reset using standard FLR methods, we should sleep
at least 100ms; in current code, it's incorrect somewhere we sleep
0.2s and somewhere 0.01s.
3) In detect_dev_info(), fix a typo: PCI_EXP_TYPE_PCI_BRIDG ->
PCI_EXP_FLAGS_TYPE.
4) fix a small typo in the comment of transform_list().

Signed-off-by: Dexuan Cui <dexuan.cui@intel.com>
17 years agoxend: Don't forget backend domain definitions for pvSCSI
Keir Fraser [Mon, 2 Mar 2009 10:22:23 +0000 (10:22 +0000)]
xend: Don't forget backend domain definitions for pvSCSI

Backend domain definitions for pvSCSI are forgotten.
This patch correctly handles them.

Signed-off-by: Masaki Kanno <kanno.masaki@jp.fujitsu.com>
17 years agox86, hvm: gcc44 build fix.
Keir Fraser [Sun, 1 Mar 2009 14:58:07 +0000 (14:58 +0000)]
x86, hvm: gcc44 build fix.

Broken constrain in inline asm.  Bytewise access works with a, b, c, d
registers only, thus "r" is wrong, it must be "q".  gcc 4.4 tries to
use the si register, which doesn't work and thus fails the build.

From: Gerd Hoffmann <kraxel@redhat.com>
Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agoxenstored: fix use-after free bug
Keir Fraser [Sun, 1 Mar 2009 14:50:04 +0000 (14:50 +0000)]
xenstored: fix use-after free bug

Problem:  Handling requests for one connection can not only zap the
connection itself, due to socket disconnects for example.  It can also
zap *other* connections, due to domain release requests.  Especially
it can zap the connection we have saved a pointer to in the "next"
variable.

From: Gerd Hoffmann <kraxel@redhat.com>
Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agox86: Relax spinlock checks during shutdown or S3.
Keir Fraser [Sun, 1 Mar 2009 14:35:57 +0000 (14:35 +0000)]
x86: Relax spinlock checks during shutdown or S3.

Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agox86, time: fix S3 suspend error
Keir Fraser [Sun, 1 Mar 2009 14:30:35 +0000 (14:30 +0000)]
x86, time: fix S3 suspend error

platform_time_calibration() is invoked in S3 when irq is disabled,
which causes ASSERT() error in spin_lock_irq(). spin_lock_irqsave()
saves us.

Signed-off-by: Guanqun Lu <guanqun.lu@intel.com>
17 years agox86, ioapic: Fix S3 suspend error.
Keir Fraser [Sun, 1 Mar 2009 14:17:08 +0000 (14:17 +0000)]
x86, ioapic: Fix S3 suspend error.

Invoke ioapic_pm_state_alloc() earlier,
thus avoiding check_lock() BUG_ON() in spin_lock().

Signed-off-by: Guanqun Lu <guanqun.lu@intel.com>
17 years agoxenconsole: Fix pty handling
Keir Fraser [Fri, 20 Feb 2009 17:02:36 +0000 (17:02 +0000)]
xenconsole: Fix pty handling

I printed the terminal attributes after openpty() and they were
garbage on the first console, valid on the second etc.
openpty() gets garbage in (uninitialized attributes MODIFIED by
cfmakeraw()). It sets the slave to the attributes requested. Using
uninitialized data for cfmakeraw->openpty results in pty attributes
that may even have the receiver disabled. Closing the slave just hides
the bug as these attributes disappear and hope the slave will be
reopened and initialized.

From: Juergen Hannken-Illjes <hannken@netbsd.org>
Signed-off-by: Christoph Egger <Christoph.Egger@amd.com>
17 years agoxenconsoled: make guest console visible on NetBSD dom0
Keir Fraser [Fri, 20 Feb 2009 11:13:11 +0000 (11:13 +0000)]
xenconsoled: make guest console visible on NetBSD dom0

After openpty(), slave_fd must be closed or guest console output goes
to the slave while select() in xen console client listens on the
master.

Signed-off-by: Christoph Egger <Christoph.Egger@amd.com>
17 years ago[VTD] Utilise the snoop control capability in shadow with VT-d code
Keir Fraser [Fri, 20 Feb 2009 11:11:40 +0000 (11:11 +0000)]
[VTD] Utilise the snoop control capability in shadow with VT-d code

We compute the shadow PAT index in leaf page entries now as:
1) No VT-d assigned: let shadow PAT index as WB, handled already
in shadow code before.
2) direct assigned MMIO area: let shadow code compute the shadow
PAT with gMTRR=UC and gPAT value.
3) Snoop control enable: let shadow PAT index as WB.
4) Snoop control disable:  let shadow code compute the shadow
PAT with gMTRR and gPAT, handled already in shadow code before

Signed-off-by: Xin, Xiaohui <xiaohui.xin@intel.com>
17 years agolibxc: xc_ptrace cleanup
Keir Fraser [Fri, 20 Feb 2009 11:09:46 +0000 (11:09 +0000)]
libxc: xc_ptrace cleanup

There are some bugs in PTRACE_PEEK/POKE.
- can't track 2MB pages in 32bit pae mode.
- leakage of mmap/munmap.

Signed-off-by: Kouya Shimura <kouya@jp.fujitsu.com>
17 years agopygrub: parse xen module option in grub
Keir Fraser [Fri, 20 Feb 2009 11:08:31 +0000 (11:08 +0000)]
pygrub: parse xen module option in grub

Add function for GrubConf to parse xen module option in grub.
Pygrub should pass args as domUloader did.

Signed-off-by: Wei Kong <weikong.cn@gmail.com>
17 years agoAMD IOMMU: clean up spinlock usage to satisfy check_lock().
Keir Fraser [Fri, 20 Feb 2009 11:05:17 +0000 (11:05 +0000)]
AMD IOMMU: clean up spinlock usage to satisfy check_lock().

Signed-off-by: Wei Wang <wei.wang2@amd.com>
17 years agoxend: Fix exception in pci_convert_sxp_to_dict()
Keir Fraser [Thu, 19 Feb 2009 11:07:33 +0000 (11:07 +0000)]
xend: Fix exception in pci_convert_sxp_to_dict()

Signed-off-by: Yosuke Iwamatsu <y-iwamatsu@ab.jp.nec.com>
17 years agoxm: Some fixes for pvSCSI
Keir Fraser [Thu, 19 Feb 2009 11:01:15 +0000 (11:01 +0000)]
xm: Some fixes for pvSCSI

For xm create and xm new, an error may not occur even if wrong
vscsi configuration is given.

e.g.
  vscsi = [ '0:0:0:0,0:0:0:0', '0:0:0:0,1:0:0:0' ]

  # xm create vm1
  Using config file "/etc/xen/vm1".
  Started domain vm1 (id=8)
  # xm scsi-list vm1
  Idx BE  state host  phy-hctl   phy   vir-hctl   devstate
  0   0   1     0     0:0:0:0    sda   0:0:0:0    None
  1   0   1     0     0:0:0:0    sda   1:0:0:0    None

This patch fixes some problems such as the above.

Signed-off-by: Masaki Kanno <kanno.masaki@jp.fujitsu.com>
17 years agovt-d: workaround for Mobile Series 4 Chipset
Keir Fraser [Thu, 19 Feb 2009 10:59:43 +0000 (10:59 +0000)]
vt-d: workaround for Mobile Series 4 Chipset

Incorporated VT-d workaround for a sighting on Intel Mobile Series 4
chipset found in Linux iommu.  The sighting is the chipset is not
reporting write buffer flush capability correctly.

Signed-off-by: Allen Kay <allen.m.kay@intel.com>
17 years agopygrub: fix for NetBSD
Keir Fraser [Thu, 19 Feb 2009 10:53:46 +0000 (10:53 +0000)]
pygrub: fix for NetBSD

Signed-off-by: Frank van der Linden <frank.vanderlinden@sun.com>
Signed-off-by: Christoph Egger <Christoph.Egger@amd.com>
17 years agox86: Fix xen panic when offlining a CPU.
Keir Fraser [Wed, 18 Feb 2009 08:59:26 +0000 (08:59 +0000)]
x86: Fix xen panic when offlining a CPU.

Also, fix a typo in a message. 'irq' => 'vector'

Signed-off-by: Kouya Shimura <kouya@jp.fujitsu.com>
17 years agovtd: fix/cleanup minor issues with multi-page qinval support
Keir Fraser [Wed, 18 Feb 2009 08:57:56 +0000 (08:57 +0000)]
vtd: fix/cleanup minor issues with multi-page qinval support

Remove MAX_QINVAL_PAGES.  Rely on whoever changes NUM_QINVAL_PAGES to
change corresponding IQA_REG_QS value also.

Signed-off-by: Allen Kay <allen.m.kay@intel.com>
17 years agovtd, x86: Fix dom0 boot crash
Keir Fraser [Wed, 18 Feb 2009 08:56:31 +0000 (08:56 +0000)]
vtd, x86: Fix dom0 boot crash

Signed-off-by: Allen Kay allen.m.kay@intel.com
17 years agoia64: Fix the missing msi.h by accident, and enhance the check
Keir Fraser [Wed, 18 Feb 2009 08:53:52 +0000 (08:53 +0000)]
ia64: Fix the missing msi.h by accident, and enhance the check
for one BUG_ON.

Signed-off-by: Xiantao Zhang <xiantao.zhang@intel.com>
17 years agoAdd missing pv_ops Linux buildconfig file.
Keir Fraser [Tue, 17 Feb 2009 11:20:18 +0000 (11:20 +0000)]
Add missing pv_ops Linux buildconfig file.

17 years agopvSCSI, xend: add new device assignment mode
Keir Fraser [Tue, 17 Feb 2009 11:19:55 +0000 (11:19 +0000)]
pvSCSI, xend: add new device assignment mode

You can use "host" mode by specifying keyword "host" as virtual scsi
device. Following is usage example.

    xm scsi-attach 1 2:0:3:4 host

In this case, all LUNs under host=2 are attached to guest domain 1.
The channel=0, target=3 and lun=4 are ignored.

Signed-off-by: Tomonari Horikoshi <t.horikoshi@jp.fujitsu.com>
Signed-off-by: Masaki Kanno <kanno.masaki@jp.fujitsu.com>
Signed-off-by: Jun Kamada <kama@jp.fujitsu.com>
17 years agoxend: Update VCPUs_live
Keir Fraser [Tue, 17 Feb 2009 11:13:34 +0000 (11:13 +0000)]
xend: Update VCPUs_live

XendConfig.py said about VCPUs_live as follows.

 -- the number of VCPUs currently up, as reported by Xen.

But the value of VCPUs_live always is 1 till xm vcpu-set get
executed.  This patch updates VCPUs_live by using online_vcpus.

Signed-off-by: Masaki Kanno <kanno.masaki@jp.fujitsu.com>
17 years agoxend: Improve information-gathering processing of SCSI devices by using lsscsi
Keir Fraser [Tue, 17 Feb 2009 11:12:50 +0000 (11:12 +0000)]
xend: Improve information-gathering processing of SCSI devices by using lsscsi

In the case of xm scsi-attach, when the SCSI devices are specified in
HCTL form or device name form, the processing is faster.

If lsscsi command is not installed, the processing works by using
information of /sys as before.

Signed-off-by: Masaki Kanno <kanno.masaki@jp.fujitsu.com>
17 years agoBUILD: Add option to build the Xen pvops git tree.
Keir Fraser [Tue, 17 Feb 2009 11:11:17 +0000 (11:11 +0000)]
BUILD: Add option to build the Xen pvops git tree.

Signed-off-by: Ian Campbell <ian.campbell@citrix.com>
17 years agoia64: Enhance vt-d support for ia64.
Keir Fraser [Tue, 17 Feb 2009 11:10:00 +0000 (11:10 +0000)]
ia64: Enhance vt-d support for ia64.

This patch targets for enhancing vt-d support for ia64.
1. reserve enough memory for building dom0 vt-d page table.
2. build 1:1 vt-d page table according to system's mem map.
3. enable vt-d interrupt support for ia64.

Signed-off-by: Xiantao Zhang <xiantao.zhang@intel.com>
Acked-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years agoxenpm tool: add average C state residency
Keir Fraser [Tue, 17 Feb 2009 11:08:31 +0000 (11:08 +0000)]
xenpm tool: add average C state residency

Signed-off-by: Yu Ke <ke.yu@intel.com>
17 years agovtd: clean up of __iommu_flush_iec()
Keir Fraser [Tue, 17 Feb 2009 11:07:29 +0000 (11:07 +0000)]
vtd: clean up of __iommu_flush_iec()

remove bogus global variable to make it local variable.

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years agopassthrough: fix MSI-X table fixmap allocation
Keir Fraser [Tue, 17 Feb 2009 11:06:16 +0000 (11:06 +0000)]
passthrough: fix MSI-X table fixmap allocation

Currently, msix table pages are allocated a fixmap page per vector,
the available fixmap pages will be depleted when assigning devices
with large number of vectors.  This patch fixes it, and a bug that
prevents cross-page MSI-X table from working properly

It now allocates msix table fixmap pages per device, if the table
entries of two msix vectors share the same page, it will only be
mapped to fixmap once. A ref count is maintained so that it can
be unmapped when all the vectors are freed.

Also changes the meaning of msi_desc->mask_base from the va of msix
table start to the va of the target entry. The former one is currently
buggy (it always maps the first page but msix can support up to 2048
entries) and can't handle separately allocated pages.

Signed-off-by: Qing He <qing.he@intel.com>
17 years agoFix typos in xendomains script.
Keir Fraser [Tue, 17 Feb 2009 11:04:08 +0000 (11:04 +0000)]
Fix typos in xendomains script.

Signed-off-by: Masaki Kanno <kanno.masaki@jp.fujitsu.com>
17 years agoMerge with ext/ia64/xen-unstable.hg
Keir Fraser [Tue, 17 Feb 2009 11:01:05 +0000 (11:01 +0000)]
Merge with ext/ia64/xen-unstable.hg

17 years ago[IA64] remove a warning.
Isaku Yamahata [Fri, 13 Feb 2009 10:11:38 +0000 (19:11 +0900)]
[IA64] remove a warning.

This patch remove the following warning.

mca.c:1928: warning: unused variable 'irq'

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years ago[IA64] remove the warning.
Isaku Yamahata [Fri, 13 Feb 2009 10:07:17 +0000 (19:07 +0900)]
[IA64] remove the warning.

iommu.c:891: warning: implicit declaration of function 'free_irq_vector'

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years ago[IA64] fix relinquish_memory()
Isaku Yamahata [Fri, 13 Feb 2009 10:03:37 +0000 (19:03 +0900)]
[IA64] fix relinquish_memory()

This patch fixes the following panic.

(XEN) Assertion 'entry->prev->next == entry' failed, line 170, file xen-unstable.hg/xen/include/xen/list.h
(XEN) Xen BUG at xen-unstable.hg/xen/include/xen/list.h:170
(XEN) FIXME: implement ia64 dump_execution_state()
(XEN)
(XEN) Call Trace:
(XEN)  [<f400000004104670>] show_stack+0x90/0xb0
(XEN)                                 sp=f0000002f64cfbf0 bsp=f0000002f64c9918
(XEN)  [<f400000004105180>] dump_stack+0x30/0x50
(XEN)                                 sp=f0000002f64cfdc0 bsp=f0000002f64c98f8
(XEN)  [<f400000004064ac0>] __bug+0x70/0xa0
(XEN)                                 sp=f0000002f64cfdc0 bsp=f0000002f64c98c8
(XEN)  [<f400000004031290>] free_domheap_pages+0x380/0x700
(XEN)                                 sp=f0000002f64cfdc0 bsp=f0000002f64c9868
(XEN)  [<f4000000040ac470>] domain_page_flush_and_put+0x1c0/0x550
(XEN)                                 sp=f0000002f64cfdc0 bsp=f0000002f64c9820
(XEN)  [<f4000000040ac990>] domain_put_page+0x190/0x530
(XEN)                                 sp=f0000002f64cfdd0 bsp=f0000002f64c97b0
(XEN)  [<f4000000040ad060>] zap_domain_page_one+0x330/0x530
(XEN)                                 sp=f0000002f64cfde0 bsp=f0000002f64c9710
(XEN)  [<f4000000040ad570>] dom0vp_zap_physmap+0x70/0xe0
(XEN)                                 sp=f0000002f64cfdf0 bsp=f0000002f64c96d8
(XEN)  [<f4000000040838f0>] do_dom0vp_op+0x320/0x7b0
(XEN)                                 sp=f0000002f64cfdf0 bsp=f0000002f64c9690
(XEN)  [<f400000004002e60>] fast_hypercall+0x170/0x310
(XEN)                                 sp=f0000002f64cfe00 bsp=f0000002f64c9690
(XEN)
(XEN) ****************************************
(XEN) Panic on CPU 2:
(XEN) Xen BUG at xen-unstable.hg/xen/include/xen/list.h:170
(XEN) ****************************************
(XEN)
(XEN) Reboot in five seconds...
(XEN) Debugging connection not set up.

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years agox86: Clean up vpt-align patch.
Keir Fraser [Fri, 13 Feb 2009 09:48:56 +0000 (09:48 +0000)]
x86: Clean up vpt-align patch.

Also disable by default if not specified in domain config. Otherwise
the feature would be incorrectly enabled for old saved domain images.

Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agohvm: Align periodic vpts.
Keir Fraser [Fri, 13 Feb 2009 09:43:06 +0000 (09:43 +0000)]
hvm: Align periodic vpts.

Aligned periodic vpts can improve the HVM guest power consumption a
lot, especially while the guest using high HZ such as 1000HZ.

Signed-off-by: Wei Gang <gang.wei@intel.com>
17 years agoxenapi: Correct some syntax errors in xen/xend/XendAPI.py
Keir Fraser [Fri, 13 Feb 2009 09:38:16 +0000 (09:38 +0000)]
xenapi: Correct some syntax errors in xen/xend/XendAPI.py

- usage of undefined variables in error cases (invalid handle
specified) in methods VBD_create, VTPM_destroy, event_unregister
- not imported module 'uuid' in method debug_create results in an
exception

Signed-off-by: Lutz Dube <Lutz.Dube@fujitsu-siemens.com>
17 years agoiommu: Fix interrupt setup.
Keir Fraser [Fri, 13 Feb 2009 09:36:58 +0000 (09:36 +0000)]
iommu: Fix interrupt setup.

Set vector_to_iommu[vector] before calling request_vector since null
pointer exceptions occur.

Signed-off-by: Kouya Shimura <kouya@jp.fujitsu.com>
17 years ago[XSM][FLASK] basic documentation and a type cast error for x86_64
Keir Fraser [Fri, 13 Feb 2009 09:33:58 +0000 (09:33 +0000)]
[XSM][FLASK] basic documentation and a type cast error for x86_64

  - A simple txt howto based on previous list discussions and observations
  - A oneliner patch to address a compiler type cast error for x86_64

Signed-off-by: George S. Coker, II <gscoker@alpha.ncsc.mil>
17 years agoxendomains: clean up output formatting
Keir Fraser [Fri, 13 Feb 2009 09:32:02 +0000 (09:32 +0000)]
xendomains: clean up output formatting

Show errors in the way they are coming from xm command only (no usage
is printed now). Watchdog_wm() has been changed for not showing dots
in the process of shutting down domains and if an error occurs it
prints target domain, operation (save/restore/migrate etc.) and reason
of failure in more user-friendly way.

Signed-off-by: Michal Novotny <minovotn@redhat.com>
17 years agox86 hvm: Allow restore of old images with different segment attribute format.
Keir Fraser [Fri, 13 Feb 2009 09:29:52 +0000 (09:29 +0000)]
x86 hvm: Allow restore of old images with different segment attribute format.
Signed-off-by: Tim Deegan <Tim.Deegan@citrix.com>
17 years ago[IA64] shrink ia64 struct page_info.
Isaku Yamahata [Fri, 13 Feb 2009 02:23:16 +0000 (11:23 +0900)]
[IA64] shrink ia64 struct page_info.

This patch is the ia64 counter part of 19107:0858f961c77a,
19132:5848b49b74fc and 19136:162cdb596b9a.
This patch shrink ia64 struct page_info and rearrange its members.

The shrinking is made compile time option in config.h with default off
becuase physical address size is architected to 50bit by ia64
and mfn isn't always addressed by 32bits with 16KB page size.

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years ago[IA64] use page_list_head and related stuff.
Isaku Yamahata [Fri, 13 Feb 2009 02:22:59 +0000 (11:22 +0900)]
[IA64] use page_list_head and related stuff.

Use page_list_head and stuff for consistency with x86 code.

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years agomerge with xen-unstable.hg
Isaku Yamahata [Fri, 13 Feb 2009 02:22:28 +0000 (11:22 +0900)]
merge with xen-unstable.hg

17 years ago[IA64] MCA: Avoid calling xmcalloc from interrupt handler
Isaku Yamahata [Fri, 13 Feb 2009 01:56:01 +0000 (10:56 +0900)]
[IA64] MCA: Avoid calling xmcalloc from interrupt handler

This patch fixes to avoid calling xmalloc() from the interrupt handler.
Calling xmalloc() with interrupt disabled triggers the following
BUG_ON().
> (XEN) Xen BUG at xmalloc_tlsf.c:548

Signed-off-by: Kazuhiro Suzuki <kaz@jp.fujitsu.com>
17 years agovtd: move the snoop control detection out of acpi_dmar_init()
Keir Fraser [Thu, 12 Feb 2009 10:54:17 +0000 (10:54 +0000)]
vtd: move the snoop control detection out of acpi_dmar_init()
where the capability value is not initialized thus we may
get random value.

Signed-off-by: Xin, Xiaohui<xiaohui.xin@intel.com>
17 years agoxm save: Display help text if bad options specified.
Keir Fraser [Thu, 12 Feb 2009 10:53:10 +0000 (10:53 +0000)]
xm save: Display help text if bad options specified.

Signed-off-by: Masaki Kanno <kanno.masaki@jp.fujitsu.com>
17 years agorombios: fix int15/86h (wait for microseconds)
Keir Fraser [Thu, 12 Feb 2009 10:52:05 +0000 (10:52 +0000)]
rombios: fix int15/86h (wait for microseconds)

The bcc compiler generates wrong stack pointer offset of a local
variable within ASM code if another local variable is declared
later.

Signed-off-by: Kouya Shimura <kouya@jp.fujitsu.com>
Signed-off-by: Akio Takebe <takebe_akio@jp.fujitsu.com>
17 years agoCleanup naming for ia64 and x86 interrupt handling functions
Keir Fraser [Thu, 12 Feb 2009 10:48:55 +0000 (10:48 +0000)]
Cleanup naming for ia64 and x86 interrupt handling functions

- Append '_IRQ' to AUTO_ASSIGN, NEVER_ASSIGN, and FREE_TO_ASSIGN
- Rename {request,setup}_irq to {request,setup}_irq_vector
- Rename free_irq to release_irq_vector
- Add {request,setup,release}_irq wrappers for their
  {request,setup,release}_irq_vector counterparts
- Added generic irq_to_vector inline for ia64
- Changed ia64 to use the new naming scheme

Signed-off-by: Espen Skoglund <espen.skoglund@netronome.com>
Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years agocpufreq: fix the build
Keir Fraser [Wed, 11 Feb 2009 16:36:59 +0000 (16:36 +0000)]
cpufreq: fix the build
Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agox86: cpufreq get_cur_val adjustment
Keir Fraser [Wed, 11 Feb 2009 13:07:45 +0000 (13:07 +0000)]
x86: cpufreq get_cur_val adjustment

c/s 19149 update cpufreq get_cur_val logic to avoid cross processor
call. However, to avoid null drv_data pointer, we adjust some logic in
this patch to keep advantage of c/s 19149 and at same time to avoid
null drv_data pointer.

Signed-off-by: Liu, Jinsong <jinsong.liu@intel.com>
17 years agocpufreq cmdline handling
Keir Fraser [Wed, 11 Feb 2009 10:47:24 +0000 (10:47 +0000)]
cpufreq cmdline handling

c/s 19147 adjust cpufreq cmdline handling, this patch is a complement
to c/s 19147.

In this patch:
1. add common para (governor independent para) handling;
2. change governor dependent para handling method, governor dependent
para will only be handled by the handler of that governor (not by all
governors);
3. add userspace governor dependent para handling;
4. change para name 'threshold' of ondemand governor to 'up_threshold'
since ondemand has only 'up_threshold', and conservative governor (will be
implemented later) has both 'up_threshold' and 'down_threshold';
5. change some coding style (c/s 19147, drivers/cpufreq/cpufreq.c) to
keep coordination with original drivers/cpufreq/cpufreq.c coding style;
(originally this file is ported from linux, we partly use linux coding style)

Signed-off-by: Liu, Jinsong <jinsong.liu@intel.com>
17 years agoxend: PCIQuirk`__devIsUnconstrained refers to an undeclared variable if
Keir Fraser [Wed, 11 Feb 2009 10:45:34 +0000 (10:45 +0000)]
xend: PCIQuirk`__devIsUnconstrained refers to an undeclared variable if
/etc/xen/xend-pci-permissive.sxp doesn't exist.

Signed-off-by: David Edmondson <dme@sun.com>
17 years agopciif: Fix typo in constant definition.
Keir Fraser [Wed, 11 Feb 2009 10:45:19 +0000 (10:45 +0000)]
pciif: Fix typo in constant definition.

Signed-off-by: David Edmondson <dme@sun.com>
17 years agoblktap: Fix check_gcrypt
Keir Fraser [Wed, 11 Feb 2009 10:44:42 +0000 (10:44 +0000)]
blktap: Fix check_gcrypt

Signed-off-by: KUWAMURA Shin'ya <kuwa@jp.fujitsu.com>
17 years agox86_64: Ensure enough space for allocator bitmap after relocated Xen image.
Keir Fraser [Wed, 11 Feb 2009 10:41:45 +0000 (10:41 +0000)]
x86_64: Ensure enough space for allocator bitmap after relocated Xen image.
Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agox86: mce: Provide extended physical CPU info.
Keir Fraser [Tue, 10 Feb 2009 05:51:00 +0000 (05:51 +0000)]
x86: mce: Provide extended physical CPU info.

Provide extended physial CPU info for the sake of dom0 MCE handling.
This information includes <cpu,core,thread> info for all logical CPUs,
cpuid information from all of them, and initial MSR values for a few
MSRs that are important to MCE handling.

Signed-off-by: Frank van der Linden <Frank.Vanderlinden@Sun.COM>
17 years agovtd: fix compilation error on ia64 for 19185:1eb6afcad849.
Keir Fraser [Tue, 10 Feb 2009 05:47:00 +0000 (05:47 +0000)]
vtd: fix compilation error on ia64 for 19185:1eb6afcad849.

Signed-off-by: KUWAMURA Shin'ya <kuwa@jp.fujitsu.com>
17 years agovtd: adding support for multiple queued invalidation pages
Keir Fraser [Mon, 9 Feb 2009 14:23:51 +0000 (14:23 +0000)]
vtd: adding support for multiple queued invalidation pages

Signed-off-by: Allen Kay <allen.m.kay@intel.com>
17 years agominios: fix p2m on x86
Keir Fraser [Mon, 9 Feb 2009 14:22:07 +0000 (14:22 +0000)]
minios: fix p2m on x86

15675:bf85b467ee89 Fixed p2m on x86_64, but instead broke it on x86.

Signed-off-by: Samuel Thibault <samuel.thibaut@ens-lyon.org>
17 years ago[IA64] fix compilation error of iommu.c
Keir Fraser [Mon, 9 Feb 2009 12:50:12 +0000 (12:50 +0000)]
[IA64] fix compilation error of iommu.c

This patch fixes the following compilation error on ia64
caused by 19178:4fcf4c9c9751.

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years agoRevert 19178:4fcf4c9c9751ccb8ed
Keir Fraser [Mon, 9 Feb 2009 12:46:26 +0000 (12:46 +0000)]
Revert 19178:4fcf4c9c9751ccb8ed

Breaks boot on every box under the sun it seems.

Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years ago[IA64] compilation fix of xentrace.
Keir Fraser [Fri, 6 Feb 2009 11:18:45 +0000 (11:18 +0000)]
[IA64] compilation fix of xentrace.

Signed-off-by: Isaku Yamahata <yamahata@valinux.co.jp>
17 years agox86: Clean up page-mfn conversion macros to allow better override by shadow code.
Keir Fraser [Fri, 6 Feb 2009 11:15:28 +0000 (11:15 +0000)]
x86: Clean up page-mfn conversion macros to allow better override by shadow code.

Also fix is_xen_heap_mfn() to deal with invalid MFNs.

Signed-off-by: Keir Fraser <keir.fraser@citrix.com>
17 years agoxenctx: print x86_32 context on x86_64
Keir Fraser [Fri, 6 Feb 2009 10:43:58 +0000 (10:43 +0000)]
xenctx: print x86_32 context on x86_64

Although x86_64 context covers x86_32, I think it's easy to watch.

Signed-off-by: Kouya Shimura <kouya@jp.fujitsu.com>
17 years agoBetter separate IOAPIC management from interrupt vector management
Keir Fraser [Fri, 6 Feb 2009 10:42:26 +0000 (10:42 +0000)]
Better separate IOAPIC management from interrupt vector management

Don't automatically update ioapic_irq array when allocating vectors.
Only do so when actually allocating IOAPIC irqs.  Also move some
IOAPIC specific defines to io_apic.c.

Signed-off-by: Espen Skoglund <espen.skoglund@netronome.com>
17 years agox86: Move interrupt vector management from io_apic.c to irq.c
Keir Fraser [Fri, 6 Feb 2009 10:40:00 +0000 (10:40 +0000)]
x86: Move interrupt vector management from io_apic.c to irq.c

Signed-off-by: Espen Skoglund <espen.skoglund@netronome.com>
17 years agox86: ->shutdown() in free_irq() should be passed vector, not irq.
Keir Fraser [Fri, 6 Feb 2009 10:39:10 +0000 (10:39 +0000)]
x86: ->shutdown() in free_irq() should be passed vector, not irq.

Signed-off-by: Espen Skoglund <espen.skoglund@netronome.com>
17 years agoCleanup IOMMU interrupt setup
Keir Fraser [Fri, 6 Feb 2009 10:36:23 +0000 (10:36 +0000)]
Cleanup IOMMU interrupt setup
- Check for errors when allocating interrupt vectors
- Clean up if interrupt allocation failed
- Make sure that the allocated vector is not reused

Signed-off-by: Espen Skoglund <espen.skoglund@netronome.com>
17 years agolibxenctrl: adds xc_domain_unbind_msi_irq to libxc.
Keir Fraser [Thu, 5 Feb 2009 15:28:09 +0000 (15:28 +0000)]
libxenctrl: adds xc_domain_unbind_msi_irq to libxc.

The function is needed to unbind MSI/MSI-X on transition from D3hot
state to D0 state.

Signed-off-by: Yuji Shimada <shimada-yxb@necst.nec.co.jp>
17 years agoFix PCI passthrough for devices w/o iomem.
Keir Fraser [Thu, 5 Feb 2009 15:08:53 +0000 (15:08 +0000)]
Fix PCI passthrough for devices w/o iomem.

From: Manuel Bouyer <bouyer@netbsd.org>
Signed-off-by: Christoph Egger <Christoph.Egger@amd.com>
17 years agox86: Use per-domain irq-to-vector array when mapping GSIs
Keir Fraser [Thu, 5 Feb 2009 12:20:18 +0000 (12:20 +0000)]
x86: Use per-domain irq-to-vector array when mapping GSIs

Using the per-domain array enables single MSI vectors to be mapped.

Signed-off-by: Espen Skoglund <espen.skoglund@netronome.com>
17 years agoxenctx support for 64-bit HVM guests
Keir Fraser [Thu, 5 Feb 2009 12:17:24 +0000 (12:17 +0000)]
xenctx support for 64-bit HVM guests
Now that we can easily find EFER.LMA, xenctx can detect 64-bit HVM
VCPUs

Signed-off-by: Tim Deegan <Tim.Deegan@citrix.com>
17 years agolibxc support for the new partial-HVM-save domctl.
Keir Fraser [Thu, 5 Feb 2009 12:17:08 +0000 (12:17 +0000)]
libxc support for the new partial-HVM-save domctl.
This includes making the pagetable walker in xc_pagetab.c behave
correctly for 32-bit and 64-bit HVM guests.

Signed-off-by: Tim Deegan <Tim.Deegan@citrix.com>
17 years agoRemove uses of DECLARE_BITMAP in the public HVM save format headers
Keir Fraser [Thu, 5 Feb 2009 12:16:53 +0000 (12:16 +0000)]
Remove uses of DECLARE_BITMAP in the public HVM save format headers
and replace them with open-coded equivalents.  DECLARE_BITMAP is
not exported to user-space consumers of the Xen headers.

Signed-off-by: Tim Deegan <Tim.Deegan@citrix.com>
17 years agoAdd a new domctl to get a single record from the HVM save context
Keir Fraser [Thu, 5 Feb 2009 12:16:28 +0000 (12:16 +0000)]
Add a new domctl to get a single record from the HVM save context

Signed-off-by: Tim Deegan <Tim.Deegan@citrix.com>
17 years agox86: recover pat value for bsp after S3 resume.
Keir Fraser [Thu, 5 Feb 2009 12:14:09 +0000 (12:14 +0000)]
x86: recover pat value for bsp after S3 resume.

host pat is set to cover all memory types by Xen, which is
necessary to support guest mtrr/pat, especially when device
is passthroughed with VT-d. However pat on bsp is not=20
recovered which could make assigned device defunct after S3
resume

Signed-off-by Kevin Tian <kevin.tian@intel.com>

17 years agox86: solve spinlock bug in s3 cpufreq path.
Keir Fraser [Thu, 5 Feb 2009 12:13:25 +0000 (12:13 +0000)]
x86: solve spinlock bug in s3 cpufreq path.

Signed-off-by Kevin Tian <kevin.tian@intel.com>

17 years agox86: EPT cleanups.
Keir Fraser [Thu, 5 Feb 2009 12:12:34 +0000 (12:12 +0000)]
x86: EPT cleanups.

Signed-off-by: Xin, Xiaohui <xiaohui.xin@intel.com>
17 years agoAdd a page_info flag to indicate whether free pages need a TLB flush
Keir Fraser [Thu, 5 Feb 2009 12:09:10 +0000 (12:09 +0000)]
Add a page_info flag to indicate whether free pages need a TLB flush
on next use.

Apart from teh small performance gain of this, my primary motivation
is to avoid TLB flushes very early in boot, when the system is not yet
properly set up for cross-TLB shootdowns.

Signed-off-by: Keir Fraser <keir.fraser@citrix.com>